草庐IT

c++ - Visual Studio 还是 GCC?

全部标签

gcc - Linux 上的 Golang c-shared - ld 找不到 -ltest

我正在尝试按照http://snowsyn.net/2016/09/11/creating-shared-libraries-in-go/中的说明进行操作我的项目比较简单。该库有一个带有println的测试函数。正如标题所说,我越来越“找不到”。我正在运行Ubuntuzesty并升级到1.7.4ls-lroy@roy-desktop:~/go/src/c$ls-l2016年合计-rw-rw-r--1royroy43Dec1006:55test.c-rw-rw-r--1royroy1274Dec1006:54test.h-rw-rw-r--1royroy2053664Dec1006:54

c++ - 如何将 CGO 用于具有条件内联函数的头文件?

我目前正在为Capi编写一个Go包装器,其中包含带有此ifdef的header:#ifdef__cplusplus#defineTEST_INLINEinline#else#defineTEST_INLINE#endifTEST_INLINEintcallC_inline(){return1;}不幸的是,我无法更改header,因为它是第三方代码。如果我将-Wl,--allow-multiple-definition传递给链接器,代码可以正常编译,但我认为这是一种不好的做法。所以,我感兴趣的是有没有我可以传递给CGO的标志或技巧来满足#ifdef__cplusplus条件?编译异常:C

在 %PATH% 中找不到 GCC

我正在尝试运行这段代码:packagemainimport("github.com/faiface/pixel""github.com/faiface/pixel/pixelgl")funcrun(){cfg:=pixelgl.WindowConfig{Title:"MyFirstprogram",Bounds:pixelgl.R(0,0,800,600)}window,err:=pixelgl.NewWindow(cfg)iferr!=nil{panic(err)}for!window.Closed(){win.Update()}}funcmain(){pixelgl.Run(run

go - GCC 未定义的构建引用

我正在尝试使用golang为windowsamd64构建一个exe。除了“gorun”或“gobuild”之外,一切都运行顺利。构建过程中断了来自github.com/andlabs/ui的包的gcc编译。跟踪如下:$gobuild#gitlab.com/asnossascenas/dbRegistration/uiC:\Users\Pat\AppData\Local\Temp\go-build167765418\gitlab.com\asnossascenas\dbRegistration\ui\_obj\table.cgo2.o:Infunction`_cgo_1e2a701ee8

amazon-web-services - AWS 单 session 还是多 session ?

我正在AWS云上托管的Golang中创建一个应用程序,它使用多种AWS服务,即S3、DynamoDB、ParameterStore。目前,处理每个AWS服务的各个模块都有自己的AWSsession。awsSession,err:=session.NewSession(&aws.Config{Region:aws.String(os.Getenv("AWS_REGION"))})从性能的角度来看,这是正确的方法,还是在主程序中创建单个session并将引用传递给单个模块会是更好的方法? 最佳答案 建议尽可能重用session。来自AW

c - 如何将返回的 uint8_u 转换为 ARM 中的 GoString?

我使用cgo从Go调用C函数。该函数的返回类型为uint8_u*。我知道它是一个字符串,需要在Go中打印它。我在myFile.go中有以下内容packagemain//#cgoCFLAGS:-g//#include//#include"cLogic.h"import"C"import("fmt""unsafe")funcmain(){myString:="DUMMY"cMyString:=C.CString(myString)deferC.free(unsafe.Pointer(cMyString))cMyInt:=C.int(10)cResult:=C.MyCFunction(cMy

c - 使用 cgo 构建共享对象时导出变量

我想使用带有选项gobuild-buildmode=c-shared的Go/Cgo构建一个.so库。函数导出良好,但我无法导出变量。我需要实现一个API,它通过调用一个void函数来工作,该函数设置各种全局属性的值。像这样:var(Gval1intGval2string//GvalN)funcf(){Gval1=1Gval2="qwerty"}.solib的客户端将运行f();之后,它可以通过寻址变量的名称来获取变量。我怎样才能导出它们?我曾尝试过这样的把戏:golangcgocan'texportvariablesbybuildmodec-shared,但没有成功(示例始终返回0,而

go - 在 Go 中按值传递还是按引用传递效率更高?

假设我有一个实现如下接口(interface)的结构:typeIFaceinterface{Method1()Method2()Method3()}typeFacestruct{Prop1stringProp2int}//IFaceimplementationhere...现在,如果我有接受IFace的方法,将其设计为接受指向该值接口(interface)的指针是否更好?接受指针:funcDummyMethod(f*IFace){(*f).Method1()}按值:funcDummyMethod(fIFace){f.Method1()}我的第一个猜测是因为这些是结构体,所以按值传递可能

c - 有没有办法在调用 MakeWS2811() 后修改 rpi-ws281x-go 库中 LED 的亮度?

我一直在使用RaspberryPi和Golang来制作一些WS2812LED的动画。我一直在使用rpi-ws281x-go(https://github.com/rpi-ws281x/rpi-ws281x-go)库,它是一个围绕C库(https://github.com/jgarff/rpi_ws281x)的Go包装器。我对C不是很熟悉,更不用说C库的Go包装器了。我可以看到在C代码中,我可以访问和更改每次调用渲染函数时应用的LED的亮度。但是,在Go包装器库中,我看不到访问该变量的方法。我可以看到,当我调用ws2811.MakeWS2811(&opt)时,我可以在opt结构中设置亮度

concurrency - 为什么并发写入的boolean值设置为false后还是true?

我正在用Go编写哲学家用餐解决方案。我的解决方案很简单:检查两个fork是否可用。如果是这样,请同时选择两者。如果不是,请保留两者。但是,我遇到了一个奇怪的并发错误,即使在明确设置为false之后,fork的可用性仍然是true。我的Fork声明如下:typeForkstruct{musync.Mutexavailbool}func(f*Fork)PickUp()bool{f.mu.Lock()iff.avail==false{f.mu.Unlock()returnfalse}f.avail=falsefmt.Println("setfalse")f.mu.Unlock()return